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(54) Digital filter with efficient quantization circuitry 



(57) An Infinite impulse response (MR) digital filter 
and method of performing the same is disclosed. The 
digital filter may be realized by way of a programmable 
logic device, such as a digital signal processor (75), or 
alternatively by way of dedicated logic including adders 
(44, 48, 50, 54, 58. 62, 66, 70. 72) and shifters (46. 52. 
56, .60, 64). In either case, additton operations (34) are 



Interleaved among first and second output sample val- 
ues (y^.^. y„.2), so that the resulting addition (30; 72; 
215; 320) may be carried out with adder circuitry of the 
same precision as the signal input (xj and signal output 
(yn). Carry control clrcuitiy (76, 78, 80, 82, 84, 88; 217; 
317) is provided to efficiently incorporate magnitude 
truncation quantization. 
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Description . 

BACKGROUND OF THE INVENTION 

5 [0001] This invention is in Ihe field of digital filters, and is nnore specifically directed to quantization techniques, 
particularly In infinite impulse response (IIR) digital filters. 

[0002] As Is well known in the art, digital signal processing is now commonly used in many electronic systems, over 
a wide range of applications. Digital signal processing techniques are now particularly commonplace in telecommuni- 
cation applications such as wireless telephones, data communications by way of modems and the like, and other facets 

10 of this field. Digital signal processing is also utilized in video and audio signal processing, such as used In image 
recognition, image processing, data connpresslon, digital audio and digital video recording and playback, and the like, 
• [0003] A fundamental building btock In the field of digital signal processing is the digital filter As is elementary in this 
field, digital filters refer to the filtering of sampled-data. or discrete-time, signals, which. are typically digital represen- 
tations of analog signals which have been generated by way of analog-to-digital conversion. Fundamentally, a digital 

IS filter is a computational process, carried out either through dedicated hardware or through the execution of a sequence 
of instructions by programmable logic, by way of which an input sequence of numbers Is converted into an output 
sequence of numbers, modified by a transfer function. Typical transfer functions refer to the frequency characteristics 
of the filter; analogously to anabg filter counterparts, examples of digital filter transfer functions include low-pass, high- 
pass, band-pass. etc. Digital filter computations typically include digital addition, digital multiplication of signal values 

20 by constants, and the insertbn of delay stages. 

[0004] As is also well known in the art. digital filters are often classified according to their impulse response. Finite 
impulse response (FIR) digital filters refer to the class of filters in which only a finite number of input samples affect 
the generation of a given output sample; typically. FIR digital fillers perform computations upon a finite number of input 
samples (i.e., the current sample, and a selected number of preceding input samples), In a non-recursive fashion. 

25 Infinite impulse response (MR) digital filters are a class of filters in which previous output samples are also used in 
generating a current output sample, and are thus typically realized in a recursive fashion, including feedback of output 
sample values. Because of the feedback of prior output values, each current output value of an IIR filter depends upon 
the value of an infinite series of input sample values, hence the term 'infinite impulse response". 
[0005] As noted above, digital filter realizations generally include multiplfeation operations, specifically the multfpli- 

30 cation of a sampled-data value by a constant value (i.e., a coefficient). According to conventional implementatfon, a 
binary multiply of an p-bit digital word by an q-bit digital word will result in a product that occupies p+q-bits. Typically, 
digital filters operate upon input and output- sample values of the same resolution, expressed by the same number of 
bits in the digital words representing these values. Accordingly, the higher precision data words resulting from the 
multiply operation are typically truncated, or quantized, to the lower-order of the output sample value. Various types 

35 of quantizatiori are known in the art, including simple truncation of lower-order bits, rounding, and magnitude truncation 
(as will be described in further detail below). In the above example, if p-bils are used to represent the input and output 
sample values, and if q-bit coefficients are utilized, the p+q-bit multiplication results will be quantized to an p-bit data 
word. . 

[0006] Quantization necessarily inserts error into the digital filter process, as the resulting quantized value is of less 
40 precision that the pre-quantization product. The resulting quantization error is of particular concern in the feedback 
paths of IIR filters, as will now be described relative to Figures la and 1 b. Figure la illustrates the recursive (feedback) 
portion of a simple first-order IIR filter 2. realized by adder 3, delay stage 4, and multiplier 5. Adder 3 receives the 
current input value x„ and the output of multiplier 5 at its inputs, and generates output value y„ at its output. Output 
value y„ is also applied to delay stage 4, for use in connection with the next sample. The output of delay stage 4 
45 corresponds to output value y^.^. since delay stage 4 incorporates a delay of one sample period. The output of delay 
stage 4 is multiplied by coefficient value a, in multiplier 5, and the product applied to adder 3 as noted above. This 
operatbn of fitter 2 may therefore be defined as: 

V 
/ 

so yn = x„+a.y^, 

where the nth output sample y^ corresponds to the sum of the current input sample with the product of the value of 
coefficient a times the prior output sample y^.^ . This simple first order filter thus has the z-domain transfer function H(z): 

' ss 

H(z) = — ^- 
1-az^ 
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where z"^ is the z-domain delay operator. Filter 2 of Figure 1a thus has a single pole, at z=a, requiring coefficient a to 
have an absolute value less than or equal to unity for stability. 

[0007] As noted above, however, for an p-bit input value x (and output value y), and assuming an q-bit coefficient a, 
the output of multiplier 5 will be an p+q-bit value. As such, some degree (specitically. q-bits) of quantization is necessary 
to generate the p-bit output sample value y. Figure lb illustrates digital filter 2\ which is constructed similarly as filter 
2 in Figure la, but which also includes quantizer 6 disposed at the output of multiplier 5, prior to adder 3. As shown In 
Figure lb, multiplier 5 generates an p+q-bIt product output that Is quantized by quantizer 6 Into an p-bIt digital word 
prior to application to adder 3. Filler 2' thus generates an p-bit output value for each input sample value x^. The 
operation of filter 2' of Figure 1b can thus be expressed as: 

where O refers to the quantization operation of quantizer 6. 

[0008] A well-known problem in MR digital fitters is referred to as "limit cycles". The limit cycle problem is manifest 
in digital filters that generate an oscillating output signal in response to a constant or zero-level input. In this regard. 
Figures 1 a and 1 b include only the recursive portions of filters 2, 2*, because limit cycles are caused only by the recursive 
feedback kx)ps. as is known in the art. It will be understood that the non-recursive (feed-tonward) portion of the filters 
will be implemented in cascade with the recursive portions shown in Figures la, lb. Refen-ing to Figure 1 b, an example 
of the generation of limit cycles responsive to a zero-level input will now be described, in the case where x„ = 0 for all 
n, where a = -14, and where y.,=7. As noted above, filter 2' of Figure lb realizes the expression of y^ = x^ + Q[a-yn.i]. 
In this example, assume that the quantization function Q Is a simple rounding function Qr. As a result, and considering 
that Xn = 0 for all n, filter 2* thus may be expressed as: 



^=QK[-|y.-.] 



50 Beginning with sample n=-1 , one may thus tabulate the values of yn as follows: 

yo = 7 ■ 

yo = QRW)] = Qp[-3.5] = -4 . 
yi=QRW)]=QR[2.01 = +2 
y2 = QRM>4(2)] = QR[.1.0] = .l 

45 y3 = QRWl)] = QRl0.51 = +1 



y4 = QR[-^M)]=QR[-o.5]=f^ 



y5 = QRWi)] = QR[o.5] = +i 



The -1 . +i sequence for output sample values y beyond ys will continue to repeat so long as the zero-level input is 
applied. 

55 [0009] As is evident from the foregoing, oscillation at the output y„ is due to the recursive state signal y„.^ being 
initially at a non-zero value, and energized over time by round-off quantizer 6. In effect, round-off quantizer 6 increases 
the amplitude of the recursive slate variable y^ in some instances, keeping this input to filter 2' from decaying to zero, 
even with input sample values x„ being zero. This limit cycle oscillation at output y„ Increases the noise floor of the 
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digital filter, reducing the signal-to-noise. ratio of the system. In addition, if the output of the digital filter is applied to 
downstream digital filter stages, the oscillation error can be unintentionally amplified, exacerbating the error 
[001 0] Other quantization approaches known in the art address the limits cycle problem. For example, the magnitude 
truncation quantization approach is defined as: 

for all X 

Mitra and Kaiser, Handbook for Dig'mi Signal Processing (Wiley. 1993). chapter 7. Magnitude truncation effectivety 
rounds off toward zero. For example. In this approach, Qmt(+3.5) = +3, and Qmt(-3-5) = -3. As a result, recursive state 
variables such as y^.^ in filter 2\ will decay to zero with zero-level input values x^. 

[0011] By way of extension, second-order IIR digital filters generally also Include quantization processes in the re- 
cursive, feedback loops. An exemplary simple transfer function, for the recursive portion of the filter only, may be 
expressed in the z-domain as follows: 

T 72 

1-a^z -a2Z 

In this filter, the coefficients a^ and ag must have absolute values less than 2 and 1 . respectively, for purposes of stability 
(i.e., to avoid the poles of the filter). A non-recursive portion of the filter may, of course, be Incorporated Into the nu- 
merator of this transfer function H(z). 

[0012] In any event, quantization will be typically utilized in typical digital realizations, as will now be described relative 
to Figures 2a and 2b. which illustrate alternative approaches In implementing quantization into secondorder IIR digital 
filters. 

[0013] In Figure 2a. filter 8 includes adders 10 and 20. Adder 10 receives the current input sample value x^ and the 
output of adder 20 at its inputs, and generates current output sample value y^ at its output. Output sample value y^ is 
fedback into filter 8 by way of delay stages 11,13, each of which encompass a delay defined by the sample period of 
filter 8; the output of delay stage 11 is applied to the input of delay stage 13, as shown. Sample y^^ at the output of 
delay stage 11 is applied to multiplier 12, and is multiplied by coefficient ai thereby; similarly sample y^g output 
of delay stage 1 3 (and which thus has been delayed by two sample periods) is applied to multiplier 14, which multiplies 
sample y^g coefficient ag. 

[001 4] As noted above, the output of multipliers 1 2, 1 4 are p+q-bit digital words, in the case where input and output 
samples x. y are p-bil words and where coefficients a^ . ag are q-bit words. In filler 8 of Figure 2a, two quantizers 16. 
18 are utilized at the outputs of multipliers 12, 14, respectively and their outputs (p-bits wide) are added by adder 20, 
the output of which is applied to adder 10. The operation realized by second-order IIR digital filter 8 may be expressed 
as: 

y„=x„ + Q[aiY^,] + Q[a2y„.2] 
This expression reflects the two quantizers 16, IB. 

[0015] In Figure 2b, filter 8' includes a single quantizer 24 is inserted between adder 22 and adder 10. The filter 
expression of filter 8' is as follows: 

As described in Bauer and Leclerc, "Computer-Aided Test for the Absence of Limit Cycles in Fixed-Point Digital Filters'. 
Transactions on S'^nal Processing (IEEE, Nov. 1 991 ), pp. 2400-241 0, the stability region within which coefficients Hi . 
32 may reside is greater for filter 8' than for filter 8. Specifically, coefficient a^ may not have an absolute value greater 
than 1 for any value of coefficient in filter 8, while in filter 8' coefficient a^ may have an absolute value greater than 
1 for some negative values of coefficient a2 (particularty as coefficient aj becomes more negative, up to its limit of -1 ). 
Accordingly, fitter 8' is often preferred, as a wider range of filter characteristics are available. 
[0016] . However, adder 22 receives the full precision results of multipliers 12, 14, and as such is realized as an p+q- 
bit adder according to conventional techriiques. Figure 3 illustrates the operation of multipliers 12. 14 and adder 22 in 
this example. As illustrated in Figure 3, multiplier 12 is realized as a series of successive shift and add operations 
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applied to output sample value y„.i from delay stage 11, in the manner defined by the non-zero bits of coefficient a^, 
with the final sum a^yn.^ being expressed as p+q-bits. Multiplier 14 is similarly arranged, and multiplies output sample 
value y^.s by coefficient a^. Adder 22 adds the two results from rnultipliers 12, 14, to derive the p+q-bit value a^y^ ^ + 

a2yn-2 

s [0017] While improved quantization is provided by the use of single quantizer 24 of filler 8*, in combination with the 
wider range of coefficients a|, ag under which stability is still maintained, the higher precision implementation of adder ' 
22 occupies a significantly greater amount of chip area, particularly if filter 8' is replicated many times in an integrated 
circuit, for example in realizing higher order fillers by the cascading of first and second order fillers. Additionally, while 
quantization error is improved by high precision adder 22 in filter 8', a certain amount of noise is generated by adder 

10 22 itself in a manner which depends upon the number of bits of precision. 

BRIEF SUMMARY OF THE INVENTION 

[0018] It is therefore an object of the present invention to provide a digital filter having a recursive path in which 
IS reduced precision adder circuitry can be utilized without increasing quantizatbn error 

[001 9] It is a further object of the present invention to provide such a digital filter which may be efficiently implemented 
in an integrated circuit, relative to chip area 

[0020] It is a further object of the present invention to provide such a digital filter which may be efficiently implemented 
relative to memory resource requirements. 
20 [0021] It is a further object of the present invention to provide such a digital filter which may be implemented as a 

dedicated, fixed-coefficient, digital filter. 

[0022] It is a further object of the present invention to provide such a digital filter which may be implemented. as a 
programmable coefficient digital filter, such as may be performed by a microcoded digital signal processor (DSP). 
[0023] Other objects and advantages of the present inventton will be apparent to those of ordinary skill In the art 
having reference to the following specification together with its drawings. 

[0024] The present invention may be implemented into a digital filter by providing an adder function in which the 
addends are multiplied by filter coefficients and added in an interleaved manner, for second-order digital IIR filters. 
Specifically, the addition and multiply operations are carried out by way of add and shifts for each non-zero bit position 
in the coefficient for each of the delayed output samples, in increasing order of the non-zero bit positions. The adder 
30 circuitry need only have the same precision as the output signal; least significant bits of the sums are retained in an 
ORed manner, for generating a carry signal at the end of the summation in order to effect magnitude truncation quan- 
. tization. 
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BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING 



[0025] Figures 1 a and 1 b are electrical diagrams, in block form, of conventbnal first-order digital filters. 
[0026] Figures 2a and 2b are electrical diagrams, in block form, of conventional second- order digital filters. 
[0027] Figure 3 is an electrical diagram, in block form, illustrating the operation and precision of multipliers and an 
adder in the digital filter of Figure 2b. 

[0028] Figure 4 is an electrical diagram, in block form, of circuitry for performing magnitude truncation quantization 
by way of two's complement quantization, according to the preferred embodiment of the invention. 
[0029] Figure 5 is an electrical diagram, in block form, of an interleaved multiply function according to th© prefen-ed 
embodiment of the invention. 

[0030] Figure 6 is an electrical diagram, in block and scherriaitic fonm, of an IIR digital filter with fixed feedback co- 
45 efficients, constructed according to a first preferred embodiment of the invention. 

[0031] Figure 7 is an electrical diagram, in block form, of a digital subscriber line system utilizing the digital filter of 
Figure 6 according to the first preferred embodiment of the invention. S' 

[0032] Figure 8 is an electrical diagram, in block form, of an analog front end function in a remote modem in the 
system of Figure 7 and utilizing the digital filler of Figure 6 according to the first preferred embodiment of the invention. 
so [0033] Figure 9 is an electrical diagram, in block fomn, of a digital signal processor constructed according to a second 
preferred embodiment of the invention. 

[0034] Figure 10 is an electrical diagram, in block form, of the datapath of the digital signal processor of Figure 9 
constructed to a first alternative implementation according to the second preferred embodiment of the invention. 
[0035] Figure 11 is an electrical diagram, in bkx;k form, of the datapath of the digital signal processor of -Figure 9 
55 constructed to a second alternative implementation according to the second preferred embodiment of the invention. 
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DETAILED DESCRIPTION OF THE INVENTION 
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[0036] As will be described in further detail hereinbelow, the preferred- embodiment of the present invention may be 
implemented into digital filters of -any type and application. However, as will become apparent from the following de- 
scription, the present invention is especially beneficial when applied to the recursive loops in infinite impulse response 
(MR) digital filters, particularly in providing an efficient quantization technique for inhibiting limit cycles. The present 
inventbn may also be used in connection with the non-recursive (i.e., feed-forward) loops in MR filters (particularly if 
similar functionality is used for the recursive loops) and in finite impulse response (FIR) fillers; however, the same 
degree of benefit may not be realized in these uses as in the feedback loops in HR filters. 

[0037] In addition, it will become apparent from the following description that various quantization approaches may 
be used in connection with the present invention. It Is contemplated, however, that magnitude truncation quantization 
is the preferred quantization approach used in the preferred embodiment of the invention. In particular, implementation 
of magnitude truncation quantization through use of a two's complement quantization approach is particularly efficient 
when realized In the preferred embodiment of the present invention, as will now be described. 
[0038] As noted above, magnitude truncation quantization has the benefit of rounding digital values toward zero in 
all cases, and thus avoiding "rounding-up" of values which can cause limit cycle behavior. According to two's comple- 
ment truncation, fractional parts of each two's complement binary value are simply discarded; in this scheme, all num- 
bers are rounded to zero, except for negative numbers having fractional portions which are rounded toward negative 
infinity. By way of example, the following table illustrates a two's complement quantization function Otc and magnitude 
truncation quantization function O^t for a number x which is represented as an integer portion I and a fractional portion 



25 



30 



X 




Qmt(x) 


+1.0 (i.e.,F=0) 


+1 


+! 


-1.0 


-1 


-1 


+I.F 


+1 


+1 


-I.F 


-1 


-1-1 



Accordingly, one may derive a relationship for magnitude truncation quantization function Q^^j based upon two's com- 
plement quantization function O^c as follows: 



35 



■I 



QTCW»forF=Oorx>0 
Qtc(x) + 1, for F;fc 0 and X < 0 
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According to the preferred embodiment of the invention, therefore, the implementation of the magnitude truncation 
quantization function Q^j may be accomplished by a single add/shHt. with two logic functions, as illustrated in Figure 
4, which will now be described in detail. 

[0039] Figure 4 illustrates nriagnitude taincation quantization function Qf^y of an p+q-brt value x by way of a two's 
complement quantization operation. As shown in Figure 4, p+q-bit value x is presented in two's complement fashion. 
Value x Is applied to an q-bH right shift process 26, in which the n least significant bits are applied, on bus LSB, to n- 
input OR gate 28. The remaining p-bits (i.e.. the m most significant bits of value x) are applied to one input of adder 
30, the other Input of which receives a fixed zero value. The most significant bit of value x (which, in two's complement 
form, indicates a negative number when 1 and a non-negative number wlflen 0) is applied on line SGN to one input of 
AND gate 29. AND gate 29 receives the output of OR gate 28 at its other Input, and applies its output to the carry-in 
input of adder 30. Adder 30 generates an p-bit output which corresponds to the result of the magnitude truncation 
functbn Q,y,j applied to input value x. 

[0040] In operation, the logical OR of the n least significant bits of input value x corresponds to a determination If 
the fractional part of input value x (i.e., the portion F) Is equal to zero. If any bit of these n LSBs is not zero, the output 
of OR gate 28 is driven high. AND gate 29 generates a carry signal to adder 30 in response to the fractional part of 
input value x being non-zero and input value x being negative (as indicated by a 1 value on line SGN). Shift function 
26 effectively divides input value x by 2". maintaining the two's complement format. Adder 30 then simply adds the 
carry-In value from AND gate 29 to the p-bit representatbn js^. from shift function 26, producing the output magnitude 
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truncation quantized value Qmt(x) shown in Figure 4. 

[0041] The performing of magnitude truncatfon quantization by using a single add/shift, with simple logic for gener- 
ating the carry-In to the add function, as shown in Figure 4. is used to advantage in carrying out the present invention. 
[0042] Referring now to Figure 5, the interleaved addition and quantization approach utilized according to the pre- 
ferred embodiment of the present invention will be described In general functional terms: Specific hardware realizations 
of the function of Figure 5 will be described, by way of example, in further detail herelnbelow. For purposes of expla- ' 
nation, Figure 5 illustrates the multiplication and addition operation: 



20 



25 



10 Sn=QMTlaiy„.i +a2y^2] 

where coefficients a-,. 82 are five-bit digital values in this example; the bit positions of these coefficients will be shown 
as a, 0 (*-SB of coefficient a,) through ag^ <MSB of coefficient ag). Result s„ of the operation of Figure 5 is the value 
added with the current input value in a recursive digital filler. For example, in filter 8' of Figure 2b, result s^ corresponds 
IS to the output of quantizer 24. 

[0043] As illustrated in Figure 5. multiplier function 32 includes a plurality of adder stages 34. Adder stage 34, 0 
receives output sample value y^.^ depending upon the state of coefficient digit a^ 0. as determined by AND function 
33. For example, ifdigit a^ 0 is zero, adder stage 34^ 0 is initially loaded with zeroes, and if digit a^ 0 is non-zero, some 
multiple of sample output value y„,., is toaded into adder stage 34, q. Coefficient digit a, q may be a single bit if coefficient 
a, is expressed in biriary terms. Alternatively, digit a, 0 may be a canonic sum digit (CSD) bit, having one of the values 
-1i 0, +1; further in the alternative, digit a, 0 may be a multiple-bit digit resulting from Booth encoding. In any event, 
adder stage 34, q is loaded in multiplier function with a value depending upon output sample value y^., and its corre- 
sponding coefficient digit a, q- 

[0044] The next adder stage 343.0 'H multiplier function 32 receives output sample value y^.g. depending upon the 
state of coefficient digit ag q; additionally, in conventional multiplier form, adder stage 342 0 ^Iso receives the contents 
of adder stage 34^ 0- performs a partial sum therewith. Adder stage 342 0. a" ^^^^^ aclder stages 34, may 
incorporate carry operations, including look-ahead carries and other types of carry propagation, as desired in the par- 
ticular implementation. The resulting contents of adder stage 342,o are forwarded to adder stage 34^ ^ 
[0045] Adder stage 34i , receives the contents of adder stage 342.o. except for the least significant bit (or bits, as 
50 the case may be) thereof which is fonwarded to result register 35. In addition, adder stage 34, , receives output sample 
value y^.^ . depending upon the state of coefficient digit a^ , . Adder stage 34^ , is shifted left by one or more bits, relative 
to adder stages 34, 342 q, depending upon the arrangement of coefficient a^ . Adder stage 34^ ^ performs the addition 
of the partial sum from adder stage 343 q and the output sample value y^.^ (as Indicated by digit a^ 1), and fon^^ards Its 
results to adder stage 342 1 another addition with output sample value y„.2 detennined by coefficient 
[0046] Multiplication process 32 then continues through the remaining adder stages 34 in a similar manner, resulting 
in a value stored in result register 35, which Is an p+q-bil register (n being 5 in this case), the n least signincant bits of 
which are derived from early ones of adder stages 34. As evident from this description, multiplication process 32 utilizes 
output sample values y^., , y^.g in an interleaved fashion, rather than performing separate multiplications as in conven- 
tional techniques as illustrated relative to Figure 3. This interleaving of the shifted additions in multiplication process 
32 permits the realization of the recursive loops In IIR digital filters to be implemented with reduced-precisbn adders, 
as there is no requirement for an p+q-bit adder for adding products a^ Y^i and a2y„.2. as is. required in conventional 
implementatbns. 

[0047] As will become apparent from the foltawing description, multiplication process 32 may be implemented with 
a reduced number of adder stages 34 if fixed-value coefficients a.,, ag are used, as only those adder stages 34 corre-. 

45 sponding to non-zero digit values affect the result. In this case, the interleaving of adder stages 34 may not be 'perfects 
(i.e., altemating between output sample values y„.,. y^g as in Figure 5), as successive adder stages associated with 
. one of the output sample values may be required if one of the coefficients includes many zero digits. On the other 
hand, as will also be described in detail hereinbetaw, the "perfect" interleaving of multiplication process 32 as shown 
in Figure 5 can be utilized where coefficients a,, 83 are programmabiri, for example as realized in a digital signal 

so processor (DSP) or other programmable logic device. 

[0048] The approach of Figure 5 according to the preserit invention also facilitates the implementation of magnitude 
truncation quantization, through the use of two's complement quantization as described above. As shown in Figure 5. 
the least significant bits from adder stages 34 are fonwarded into result register 35. In effect, these least significant bits 
indicate whether any fractional portion of the final sum remains; this determines, for negative final sums, whether a 

55 carry bit must be generated in order to convert the quantization f unctfon from two's complement quantization to mag- 
nitude truncation quantization. Accordingly, these least significant bits are effectively ORed by OR function 28, and 
applied as a carry-in to adder 30 depending upon the state of the sign-bit of result register 35, under the control of 
AND function 29. The output of adder 30 provides sum S^, which is then added to the input sample value x^ in realizing 
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an IIR digital filter as discussed above. This magnitude truncation quantization eliminates limit cycles which, as de- 
scribed above, appear as periodic output noise generated by an IIR filter when zero-level input is provided. As is known 
in the art, limit cycles may also occur when a constant non-zero input is applied to an IIR filter; it is contemplated that 
the present invention may also resolve this type of limit cycle issue through use of a high-pass filter which removes 
DC components of the Input signal prior to application of the IIR digital filter described herein. 
[0049] Furthermore, while second-order filters are implemented according to the present invention, as described 
hereinabove relative to Figures 4 and 5 and as described hereinbelow, it is contemplated that the present Invention 
may be utilized in higher-order filters as well. It is particularly conlemplaled. that, as known in the art, higher order 
filters are realized by cascading first and second order filters, in which case the preferred embodiments of the invention 
described hereinbelow may be directly used. Alternatively, it is contemplated that those of ordinary skill in the art. 
having reference to this specification, will be readily able to implement higher-order filters using the present invention. 
[0050] According to a first preferred embodiment of the invention, a recursive loop in a second-order IIR digital filter 
having fixed coefficients a^ , ag will now be described in detail. As noted above, additional implementation efficiency is 
provided by the fixed nature of coefficients a^. ag, as only those adder stages in effecting non-zero coefficient digits 
are necessary. As a result, the recursive loop of IIR digital filters may be readily and efficiently implemented, particularly 
in cases where the filter design selects values of coefficients a,, ag that involve relatively few non-zero digits. 
[0051] According to this first preferred embodiment of the invention, coefficients a.,, ag are implemented by way of 
canonic sum digits (CSDs), such that each digit position can represent -1 , 0. or +1 . This representation is particularly 
useful in the case where the values of coefficients a^, ag have fixed values, as will now be described. 
[0052] In general, the implementation of a limit -cycle-free IIR digital filter recursive path, using fixed coefficients 
expressed in CSD form, can be expressed algorithmically as a sequence of partial sums S. Coefficient a. having an 
absolute value less than or equal to 2, may be represented by: 



25 



i-0 

30 where Cj G {-1 , 0, +1 }, and where N is the number of CSDs in coefficient a. The product ay„.^ thus may be expressed as: 



N-l 

^y^i =Zci(yo.i)2'' 

35 



This implies that the product ay^.^ may be obtained by summing the terms Cj(y^i)2-^ for non-zero digits Cp requiring 
only shift and add operations. Algorrthmically, consider Sj as the jth partial sum of Cj(yn.i)2-'. Then: 

40 

where Cjq is the lowest-order non-zero CSD digit of coefficient a. The next partial sum S, is thus: 

45 

50 where j1 -jO is the binary exponent difference between the second and first non-zero CSD digits Cj^, Cp, respectively, 
of coefficient a, and where bracket l J indicate rounding toward -oo. In conventional adder circuitry, partial sum S, is 
shifted left (i.e,. higher-order) by the number of bits defined by 2-0^-iO), and Is limited by the signal word length. This 
limitatbn on the word length of the partial sums S leaves a fractional portk>n F, represented as foltaws: 




WSDOCID: <EP ^0948133A2J_> 



8 



EP 0 948 133 A2 




5 

Where the brackets 1 indicate rounding toward -h». This fractional portion is 1 if the difference is non-zero. The 
next partial sum S2, based upon the next non-zero, digil Cj2. is similarly generated: 

I s, r 

IS 

with a fractional remainder generated by: 



20 




where v indicates a bit-by-bit logical OR. This logical OR operation ensures that all subsequent fractional portions 
remain unity if any lower-order fractional portion F is unity. Upon completion of the final partial sum Sj. a final addition 
is perfomned to generate a final sum Sj^^ , using a carry based upon the f ractbnal portion Fj if the final partial sum Sj 
is negative. This final addition implements the magnitude truncation quantization, in the manner described above, as 
foltows: 



30 QMT(a.y^i)=Sj-^C,„ 
where 



^ fl,forS, <OandFj ?tO 

" [ 0, otherwise 

[0053] Referring now to Figure 6, an example of an implementation of this algorithm for generating a magnitude 
40 truncation quantized sum of products of coefficients and output sample values in a second-order IIR digital filter 40, 
according to a first preferred embodiment of the present invention, will now be described. According to this first preferred 
embodiment of the present invention, the coefficients a^, ag are fixed in value, and are represented in CSD form. 
Accordingly, this embodiment of the invention will be described by way of an example in which values for coefficients 
a^, ag are selected. 

45 [00S4] Figure 6 illustrates digital filler 40 as having a non-recursive part 42, which processes cun-ent input sample 
value typically in combination with prior input sample values x^i^ as known in the art; the output of non-recursive 
part 42 is applied to one input of adder 72. which generates current output sample value y„ as the sum of the output 
of non-recursive part 42 and the output of the recursive part of digital filter 40 which will be. described in detail below. 
In the example of Figure 6, input sample value is first applied to high-pass filter 41 , so that digital filter 40 is protected 

so not only from limit cycles in the event of zero-level input, but also in the event of constant-level input at any DC level; 
high-pass filter 41 is, of course, optional in implementing the present invention. The current output sample y„ is applied 
to delay stage 74, which produces previous output sample values y^.^, y^2 ^or use in subsequent samples of second- 
order IIR digital filler 40. As illustrated in Figure 6. previous output sample values y^.,, y^2 are applied to a series of 
add and shift stages, as will now be described. 

ss [0055] In this example, coefficients a^, 32 are set as follows: 
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a. = 1.82153 = 2-X + X6-^X28 + X( 



1024 



10 



IS 



20 



30 



40 



= -0.868127 = - I + X+X28-X024 



As such, since both coefficients 82 have their least significant non-zero digit at the same power of two, output 
sample values y^.^ and y„.2 are each applied to an input of adder 44, with output sample value y^.g inverted (indicated 
by the minus sign) because of the sign of its least significant digit. Referring back to the algorithmic description of this 
operatbn, first partial sum Sq thus corresponds to output sample value y^.^. and the next partial sum corresponds 
to the sum y^.^ + (-yn-a)- Partial sum is then applied to 3-bit shifter 46. 

[0056] 3-bit shifter 46 carries out a three-bit right-shift of partial sum S,, fonwarding the three least significant bits to 
OR gate 76 as fractional portion F1 , and forwarding the rem9ining most significant bits to adder 48. In effect, shifter 
46 is executing a portion of two's complement quantization, by discarding fractional portion F., from partial sum S-,. 
The shift executed by shifter 46 is a three-bit shift, considering that the next least significant non-zero digit in either of 
coefficients ai , 82 differs from the prior non-zero digit by a factor of 2^ (2-^ ^ 2-^^). Adder 48 also receives output sample 
value y^.^. and fonwards its output (partial sum S2) to one input of adder 50. which receives output sample value ^^.2 
at its other input. No shifter is present between adders 48. 50. as each of coefficients 81, 82 have a non-zero digit in 
this same bit position {2r^). The output of adder 50 corresponds to partial sum S3, and is applied to 3-bit shifter 52, 
considering that the next least significant non-zero digit (2^ in coefficient a,) in either of coefficients a^ , ag differs from 
the previous (2*7) by a factor of 2^. Fractional portion F3 Is fonwarded from shifter 52 to OR gate 78, which also receives 
25 the output of OR gate 76 at another input; in this way. any non-zero fractional portion in least significant bit positions 
. (e-Q-. Fi) propagates through OR gate 78. 

[0057] The shifted output from shifter 52 is applied to adder 54. which receives output sample value y^^ at its other 
input, and which generates partial sum S4 at its output. Partial sum S4 is applied to one-bit shifter 56, considering that 
the next least significant non-zero digit (2-3 in coefficient Sj) differs from the previous by a factor of 2. Shifter 56 thus 
generates a one-bit fractional portion F4 applied to OR gate 80 along with the output of OR gate 78; the shifted output 
from shifter 56 is applied to one input of adder 58, which receives coefficient y^g its other input. The output of adder 
58, corresponding to partial sum 85 is applied to one-bit shifter 60. as the next least significant nonrzero digit (-2-2 in 
coefficient a, ) differs from the previous (2-3 in coefficient ag). Shifter 60 generates a one-bit fractional portion F5, which 
is applied to one input of OR gate 82, the other Input of which receives the output of OR gate 80. 
35 [0058] Shifter 60 also forwards the shifted partial sum S5 to one input of adder 62. Because the non-zero coefficient 
digit (2-2 in coefTicienl a^) is negative, adder 62 receives the inverted value of output sample value y^.,, based upon 
which it generates partial sum S5 which is applied to 2-bit shifter 64 (considering that the next non-zero coefficient digit 
is -2° in coefficient ag. Shifter 64 generates a two-bit fractional portion Fe, and applies these two bits to OR gate 84, 
which also receives the output of OR gate 82. The shifted output of shifter 64 is applied to one input of adder 66. which 
receives output sample value y^2 (inverted by the negative coefficient ag digit in the 2° place) at its other input, and 
which generates partial sum Sy.at its output. As this partial sum is based upon the 29 coefficient digit, no fractional 
portion is generated. Partial sum is applied to one input of adder 70. Output sample value y^^ is applied to one-bit 
shifter 68, to effect a multiply-by-two operation (considering most significant digit 2^ in coefficient a^ ), the result of which 
is applied to another input of adder 70. Adder 70 generates final partial sum §5, which Is applied to final adder 72. 
^5 [0059] The output of OR gate 84 Is based upon the slate of the fractional portions F, through Fg generated by the 
various shifters in digrtal filter 40; the output of OR gate 84 is low ("O") only if all fractional portions F^ through Fg are 
. zero. OR gate 84 presents its output to one Input of AND gate 88. the other.input of which receives the most significant 
(i.e., sign) bit from final partial sum Sg. As described above, because twq's complement quantization is being carried 
out, conversion to magnitude truncation quantization is carried out by adding "1" to the final partial sum if the final 
partial sum is both negative and not an integer. As such, AND gate 88 generates a signal at Its output, on line Ci„ which 
is applied to final adder 72. in response to line SGN being high (indicating that two's complement final partial sum Sq 
is negative) in combination with the output of OR gate 84 being high (at least one of the fractional portions F, through 
Fg being non-zero). Final adder 72 adds the final partial sum Sg, carry-in-bit C-^, and the output of non-recursive portion 
42, to generate current output sample value y„. 
55 [0060] As illustrated by this exemplary embodiment of Figure 6, IIR digital filter 60 efficiently incorporates the recursive 
loop without requiring adders that are of extended precision relative to the signal values; each of adders 44, 48. 50. 
54, 58. 62, 66, 70, 72 are p-bit adders, in this case where output sample value y^ is an p-bit value. Additionally, because 
of the magnitude truncation quantization that is implemented in this example, limit cycles are precluded from occurring 
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in digital filter 40 in the event of a zero-level input (or, considering the presence of high-pass filter 41. in the event of 
any constant-level input). 

[0061] Digital filter 40 according to this first preferred embodiment of the present invention, considering that coeffi- 
cients ai . ag have fixed values, is contemplated to be of particularly beneficial use in those applications that may utilize 
a dedicated digital signal processing function. Figure 7 illustrates an example of such an application. In which digital 
filter 40 is included within an analog front-end" function of a digital subscriber line (DSL) modem In a telecommunica- 
tions system. 

[0062] Figure 7 illustrates a typical system installation of DSL services, in which multiple remote subscribers interface 
with a telephone system central office. In this example, a user in a home or office environment operates remote com- 
puter system R, such as a personal computer or workstation, or alternatively an entertainment unit in the video-on- 
demand (VOD) context. Each of remote computer systems R serves as a remote source and destination of commu- 
nicated data, which may be representative of text, graphics, motion pictures, audio, etc. Each remote system R is 
associated with a remote DSL modem 115, by way of which the remote system R communicates with central office 
DSM modem 108 over a conventional twisted-pair telephone facility TWR One or more telephones (not shown) may 
also be connected into each twisted pair wire facility TWP, such that "Plain Old Telephone Sen/lce" (POTS) voice 
communications may alternatively or additionally be communicated over twisted pair wire facility TWR The DSL tech- 
nology in the specific example of Figure 7 may be of the asymmetric type (I.e. . ADSL), with traffic traveling from central 
office modem 108 to remote modems 115 at a signal bandwidth that is higher in frequency than that of traffic traveling 
from remote modems 115 to central office modem 108 (i.e., upstream). 

[0063] As illustrated in Figure 7, each of twisted pair wire facilities TWP is received by central office DSL modem 
108, which is contemplated to be located in a central office of the local or long distance telephone sen^ice provider. 
Central office modem 108. in this example, is capable of receiving multiple twisted pair wire facilities TWP (only two 
of which are illustrated in this example). Central office modem 108 provides communication of data between twisted 
pair wire facilities TWP, and thus remote systems R, and a host computer (not shown in Figure 7) which sen/es as the 
source or destination of data, or as an intermediate gateway to a network, such as the Internet, or a dedicated "dial- 
up" content provider or network. Of course, the central office will typically also include switchgear for the routing of ' 
calls such as those placed by remote systems R (or associated telephones) over twisted pair wire facilities TWP. As • 
noted above, central office modem 1 08 will likely be connected to a backbone network, which in turn Is in communication 
with other communication paths by way of equipment such as routers or Digital Subscriber Line Access Multiplexers 
(DSLAMs). In the application where POTS servtee overlays the ADSL data traffic, such equipment may also include 
some type of "splitter" for separating POTS from the data traffic, routing the POTS traffic to the conventional telephone 
. network (PSTN) and routing the data to a wide-area network (WAN). 

[0064] In the example of Figure 7, remote DSL modems 115 are each arranged as a plurality of functions, which 
roughly correspond to individual integrated circuits in this exemplary embodiment of the invention. It is of course to be 
understood that the partfcular integrated circuit, or "chip", boundaries among these vartaus functions may vary among 
implementations; the exemplary realization illustrated In Figure 7 is provided by way of example only. In this example, 
each of remote DSL modems 115 include a host interface 107, for interfacing digital transceiver function 113 with its 
associated remote system R. Host Interface 1 07 is of conventional constructbn for such interface functions, an example 
of which Is the TNETD2100 digital serial bus interface circuit available from Texas Instruments Incorporated 
[0065] According to this embodiment of the invention, digital transceiver function 1 1 3 in remote DSL modems 1 1 5 is 
a programmable device for executing the necessary digital processing operations for both transmission and receipt of 
the data payload. These operations include such functions as formatting of the digital data from the host computer 
system (into packets and frames, for example), encoding of the data into appropriate subchannels for transmission, 
and performing an inverse Fast Fourier Transform (IFFT) to transfonn the encoded data into time domain signals; on 
the receive side, digital transceiver function 1 3 performs the reverse of these operations, as well as echo cancellation 
processing. Particularly at the data rates discussed hereinabove, the digital data processing capacity and power of 
digital transceiver function 113 is preferably of a high level; an example'^bf an architecture suitable for use as digital 
transceiver function 113 is a digital signal, processor such as the TMS320C6x type, available from Texas Instruments 
Incorporated. 

[0066] Each digital transceiver function 113 is bidirectionally connected to AFE 111. which is a mixed-signal (i.e., 
involving both digital and analog operations) integrated circuit which provides all loop interface components necessary 
for DSL communications other than those which involve high voltages. In this regard, AFEs 111 in each of remote DSL 
modems 115 perfomn both transmit and receive interface functions. In turn. AFEs 111 in each of remote modems 115 
bidirectbnally Interface with line driver 117, which is a high-speed fine driver and receiver for driving and receiving the 
ADSL signals on twisted pair facility TWP, such as the THS6002 line driver available from Texas Jnstmments Incorpo- 
rated. Line drivers 117 in remote modems 115 are connected to a four-wire to two-wire "hybrid" integrated circuit 119, 
which converts the dedicated transmit and receive lines from line driver 117 to the two-wire arrangement of twisted 
pair facility TWR in full-duplex fashion. 
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[0067] In the central office, central office DSL nDodem 108 Includes host interface 109 which connects modem 108 
to a host computer (not shown). Host interface 109 may, as noted above, be Implemented by conventional circuitry 
such as the TNETD2100 digital serial bus Interface circuit available from Texas Instruments Incorporated. As noted 
above, the host computer will interlace central office modem 108 to a splitter tor separating POTS from the data traffic, 
5 as noted above, and thus to the conventional telephone network (PSTN) and wide-area network (WAN) as appropriate 
for the semce being provided. Central office modem 8 includes digital DSL transceiver function 110, which connects 
to multiple analog front end functions (AFEs) 112 as shown in Figure 7. 

[0068] Digital transceiver function 1 1 0 is similarly constructed as and performs similar processing to digital transceiver 
functions 113 in remote DSL modems 115, with certain differences in function arising- from the different frequencies 
10 of its received and transmitted traffic, as will be described in detail hereinbebw. As before, digital transceiver function 
1 10 is preferably implemented as a high-perfomiance digital signal processor, such as the TMS320C6x, available from 
Texas Instruments Incorporated. 

[0069] Digital filter 40, described hereinabove relative to Figure 6, may be Implemented In its dedicated, fixed coef- 
ficient, form, in AFEs 111, 112, particularly at those locations at which IIR digital filtering is to be performed. Referring 
IS now to Figure 8, an example of the arrangement of AFE 111 in remote modems 115 which incorporates digital filter 40 
will now be illustrated. 

[0070] Referring now to Figure 8, the construction and operation of AFE 111 in remote modems 115 will now be 
described in detail; the construction of AFE 112 in central office modem 108 may be quite similar, but of course will be 
modified as necessary to handle the different bandwidth signals. As noted above, it Is contemplated that AFE 111 may 
20 be readily integrated into a single integrated circuit, either limited to its functions or alternatively integrated with certain 
of the other functions such as digital transceiver function 113, line driver 117, and-the like. AFE 111 according to this 
embodiment of the present invention is intended to provide all loop interface components that are not exposed to high 
voltages, such as a high-pass filter, transmitter power driver, four-wire to two-wire hybrid, and a receiver coarse pro- 
gramnnable gain amplifier, such elements being external to AFE 111 (e.g.. implemented within line driver 11 7 and hybrid 

25 119). 

[0071] AFE 111 includes a transmit side and a receive side, along with a second transmit side 153, which is identical 
to the signal transmit side illustrated in Figure 8, for purposes of providing time domain echo cancellation. In this regard, 
echo cancellation transmit side 153 drives lines ECP, ECM with analog signals corresponding to those generated by 
AFE 111 on lines TXP, TXM; lines ECP, ECM are applied to common nodes RXP, RXM extemally from AFE 111 (e.g.. 
30 at line driver 1 1 7). to provide a copy of the low-frequency upstream transmit signal that can be used by digital transceiver 
function 1 1 3 to cancel any echo signal generated by the transmit side of AFE 1 1 1 

[0072] In this embodiment of the invention, the transmit (both primary and echo cancellation transmit side 153) and 
receive sides share interface and control function 142R, by way of which AFE 111 communicates with digital transceiver 
113. Interface and control function 142R Includes a parallel digital interface, by way of whteh digital words to be trans- 

35 mitted by remote system 108 are received by AFE ill. and by way of which data received from twisted pair facility 
TWP and processed by AFE 111 are communicated as digital words to digital transceiver 113. Interface and control 
function 142R also includes the appropriate signal Interface for receiving and providing control informatbn from and 
to digital transceiver 113. Clock circuitry 166R is shared by the transmit and receive sides of AFE 111, and provides 
the corresponding clock control for synchronous operation thereof. Voltage reference 1 68R. preferably a stable voltage 

40 reference circuit isuch as a bandgap reference, is also shared by the transmit and receive sides of AFE 111. Other 
circuitry used in the operation of AFE 111. such as power supply distribution and regulation, general purpose port 
communicatfons, and the like, may of course also be included therein, but Is not shown for purposes of clarity of this 
description. As shown in Figure 8, AFE 111 also includes oversampling register 44R which comprises one or more 
register stages, as may be used in AFE 11 1 in realizing certain digital filter operattons. 

^ [0073] Referring now to the signal transmit side of AFE 11 1 = digital filler 1 40 receives digital data words from over- 
sampling registers 1 44R, and implement digital filter operations upon these digital data words, prior to diglta Mo-analog 
conversion. The digital filtering process executed by AFE 111 may include multiple options and functbns. selectable 
depending upon the frequency and characteristics of the digital data provided by digital transceiver function 110. Such 
multiple functions may include an interpolation fitter for increasing the sample rate, and a digital high pass filter. 

50 [0074] It is contemplated that digital filters 140 In AFE 111 will typically include a digital low pass filter, however to 
effect band-limiting on the digital data so as to ease the complexity of the downstream analog filtering. It has been 
observed, according to the present invention, that the analog filtering of upstream DSL communications can be reduced 
from a fourth order analog fitter to a second order analog filter through use of a digital low pass filter; noise contribution 
of downstream analog filtering Is also reduced, as well. According to the preferred embodiment of the invention, such 

55 a digital low pass filter process is realized In digital fitter 1 40 by way of an infinite impulse response (IIR) Implementatfon 
with a comer frequency at about the high frequency limit of the lower-frequency bandwidth. A particulariy advantageous 
realization of digital low pass filter is a third order IIR filter that approximates an elliptic response with minimal tfcO.5 
dB) pass-band ripple. A preferred exemplary realization utilizes a time-domain filter equation as foltows: 



12 



iNSDOCIO: <EP. 



J0948133A2_L> 



EP 0 948 133 A2 



y.n = ^iVn-l ^aaVn-a +33yn-3 +^2X^2 +^3X^3 



Where the tap weight coefficients are defined as follows: 



5 



b,=b3 = 2*^2' 
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a^ =2 + 2"^ +2'^ +2"* -2'® -2' 



IS 



a2 = -2-2"V2" 



a. 



I3 = 2''' + 2"^ -2' 



1-9 



20 



This particular implementations deviates from the ideal digital elliptic filter to a slight extent, in order to reduce circuit 
complexity by maintaining powers-of-two coefficients (which may be implemented without multipliers). This deviatbn 
has been observed to result only in a 0.25 dB droop at the corner frequency, which is tolerable in this application, and 
involving minimal group delay. 

25 [0075] According to the preferred embodiment of the inventbn. and particularly for implementing a known standard 
such as the T1 El .41 3 standard, this third-order MR digital fitter is implemented In AFE 1 11 by way of a second-order 
IIR filter as described above as digital filter 40, in cascade with a first-order filter to achieve the proper characteristic. 
Further, considering that AFE 111 is preferably integrated into a single integrated circuit, the tap weight coefficients 
noted above are preferably hard-wired into AFE 111 through the construction of the shift and add stages in digital filter 

30 140, as described above relative to Figure 6. The advantages of efficient integration, and limit-cycle free operation, 
will be of significant benefit in the DSL communications provided by way of AFE 111 . 

[0076] Referring back to Figure 8,.the output of digital filter 1 40 is then applied to digital-to-analog converter (DAC) 
1 48R for conversion into an analog signal. The analog output of DAC 1 48R is filtered by analog low-pass fitter 1 50R, 
for example by way of a second-order Chebyshev continuous-time filter, implemented according to conventional tech- 

35 niques, and having a nominal 166 kHz passband. This relatively simple analog filter is enabled by the extent of the 
digital filtering previously provided by filters 1 40 discussed above. The output of anatog low pass filter 1 50R Is presented 
to prqgrammable attenuator 152R, which is constructed according to conventional techniques to provkJe 0 dB to -24 
dB attenuation, selectable in 1 dB steps. The output of programmable attenuator 1 52R is presented on lines TXR TXM 
to line driver 117, and corresponds to an analog signal corresponding to the data to be transmitted, encoded in the 

40 manner implemented by digital transceiver 11 3, and with the frequency characteristics specified by the applicable DSL 
standard, such as T1 El .413. 

[0077] Referring now to the receive side of AFE 1 1 1 , lines RXR RXM. which are driven by line driver 1 1 7 in response 
to communfcatkxj signals received over twisted pair facility TWP from central office modem 8, are received by equalizer 
57 which compensates for line attenuation over twisted pair facility TWR particulariy at the higher frequencies at which 

45 downstream data are communrcated in ADSL technology. The output of equalizer 157 is applied to anatog low pass 
filter 158R which, in this example, is a fourth order elliptic continuous-time filter having a nominal 1.325 MHz pass 
band. The output of analog tow pass filter 1 58R is applied to programmable again amplifier 1 60R which, in this example, 
provides a frequency independent gain over the signal bandwidth of 30 |(hz to 1104 kHz ranging from about 2.5 dB to 
about 11.5'dB in 0.25 dB steps. The output of second programmable' ^ain amplifier 160R is applied to ADC 162R, 

so : converts the received analog signal into digital words at a fixed sample rate. 

[0078] The output Of ADC 162R is applied to digital filters 164R which, in this example, performs a two-pole, two- 
zero digital low pass filter function, to attenuate noise generated by equalizer 157 and analog low-pass filter 158R. 
Additional digital filtering, including a decimation filter to reduce the sample rate. While digital filters 164R may utilize 
the -present invention, for example according to the first preferred embodiment described hereinabove, it is contem- 

55 plated that these filters may be realized by way of FIR filters. In which case the particular benefits of eliminating limit 
cycles provided by the present Invention would not be obtained. The output of digital filters 164R is then presented to" 
Interface and control circuitry 142R. for communication to digital transceiver 11 3 as noted above. 
[0079] AFE 112may be constructed similarly as AFE 111, but with differences Incorporated thereinto because of the 
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different frequency bands utilized for upstream and downstream communication in ADSL technology. To the extent 
that HR digital filters are implemented within AFE 112, the present invention, particularly in the case of fixed coefficient 
recursive loop design as described hereinabove relative to Figure 6. will be of particular benefit. 
[0080] According to a second preferred embodiment of the present invention, the digital filter coefficient values are 

5 programmable, so as to be selectable under software control. This second preferred embodiment of the invention 
therefore necessarily requires "perfect" Interleaving of adder stages, such as described hereinabove relative to Figure 
5, as the coefficient values will be able to take any one of a number of values within a certain range in this programmable 
embodiment. As such, it is contemplated that the programmabilily of coefficient values In the recursive loop of an IIR 
digital filter, according to the present invention, will be best accomplished in a programmable logic device, such as a 

^0 digital signal processor (DSP), as will be described hereinbelow relative to a second-order MR digital filter. 

[0081] According to this second preferred embodiment of the present invention, the coefficients , are preferably 
Booth encoded in computing the product aj y„.|. Booth encoding, which is a well-known technique used in digital mul- 
tipliers, considers the multiplier (i.e., coefficient) in groups of bits, and assigns a multiplicative factor to each group. 
For example, three-bit Booth encoding considers three bit groups of the multiplier (with one-bit overlap between groups). 

^5 and assigns a multiplicative factor from the set of {-2, -1 , 0, +1 , +2} for the group. In the case of a second-order digital 
filter where each coefficient a^, ag has an even number of bits, fewer than the number of bits of the output sample 
values y„.i. y„.2, three-bit Booth encoding will reduce the number of steps required to compute the product ^yiT[aiy^, 
■+ ^z^n-^ 3 factor of two from that which would be required in a pure binary multiplication. 
[0082] The operations required to compute this product will now be described in terms of an algorithm. In this de- 
20 scription, the Booth encoding begins with generation of a first Booth term Bootho. which uses bits Ci. and Cq of a 
coefficient a. together with a lower-order "0". The first partial sum S© is given by; * 

So=:Bootho(y„..,) 

25 

The next partial sum S^ utilizes the Booth encoding of bits Cg, Cg, of coefficient a to generate a Booth term Booth^- 



S, =Boothi(y^,) + 



A first fractional part results from the effective shifting of the product, as follows: 

35 
40 

The generation of these partial sums continue, with each successive partial sum S including divisbn of the previous 
partial sum by a factor of 4 (considering that three-bit Booth encoding is being used). In general: 

45 



50 

and 
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The final sum Sj is generated as simply the sum of Sj.^ and a carry in. where the carry in is computed as discussed 
above (i.e.. '1 " for a final partial sum Sj., that is both negative and not an integer; "0" othenwise). 
[0083] This algorithm may be readily implemented into the architecture of a digital signal processor (DSP), as will 
now be described in detail relative to Figure 9. In Figure 9, DSP 75 is illustrated in block form. According to this em- 
bodiment of the invention. DSP 75 Includes random access memory (RAM) 76. readK>nly memory (ROM) 78, datapath 
(also referred to as an arithmetic logic unit, or ALU) 80, and controller 82. In this embodiment of the invention, input 
sample values are received by DSP 75 by datapath 80 polling external register (EREG) 77, and communicating the 
input values lo RAM 76. Datapath 80 is controlled, in this embodiment of the invention, by DSP controller 82 which 
responds to instruction codes retrieved from ROM 78 according to an address stored in program counter 79. such 
instruction codes being buffered by instructbn register 81 prior to being applied to DSP controller 82. Control register 
83 is provided, in communication with DSP controller 82 and datapath 80. for storing control and status information. 
Data register (DREG) 85 in datapath 80 stores the output result, for presentation upon data lines D; for example, when 
DSP 75 is executing a digital filter operation as will be described In detail herelnbelow, DREG 85 will buffer output 
sample values yn. 

[0084] Referring now to Figure 10, the construction of datapath 80 according to a first realization of this second 
preferred embodiment of the invention will now be described in detail. In the example of datapath 80. Input sample 
values are received from EREG 77 and applied, via multiplexer 204, to RAM 76. Data read from RAM 76 are applied 
to inputs of multiplexers 200A, 200C. 200B, as are data from adder 215 in datapath 80. Data from RAM 76 may also 
be input to R register 205 and S register 207 which, according to this embodiment of the present invention, store the 
coefficient values a, , agi the contents of registers 205. 207 are forwarded to DSP cOTtroller 82, which controls datapath 
80 to execute the appropriate shift and multiply operations based upon these coefficients a^, a2. Multiplexers 200A. 
200C, 200B have their outputs applied to registers 202A, 202C. 202B. respectively; control Inputs (not shown) from 
DSP controller 82 control the selections made by multiplexers 200 according to the particular Instruction under execu- 
tion. 

[0085] The output of registers 202A, 202C are applied to memory multiplexer 204, by way of which data are written 
from datapath 80 to RAM 76. These outputs of registers 202A, 202C are also applied to inputs of multiplexer 206, 
which has an output forwarded to a series of arithmetic and logic units. These ALUs include Booth encoded multiplier 
210. and exclusive-OR function 212. Together, multiplier 210 and XOR 212 multiply an operand by a selected value 
In the set {-2, -1, 0, +1, +2}. depending upon the state of control lines (not shown) applied thereto by DSP controller 
82; in this embodiment of the invention, DSP controller 82 issues the appropriate Booth encoded value based upon 
the values in registers 205, 207, the selected bit group therein, and the particular cycle under execution. Exclusive- 
OR block 21 2 follows Booth encoded multiplier 21 2, after which clip circuit 214 is provided to prevent overHow conditions 
in the final result. The output of clip circuit 21 4 is applied to one input of adder 215. 

[0086] Alternatively, datapath 80 may utilize alternative coefficient formats In performing the appropriate add and 
shift operations In effecting the interleaved multiplication operation according to the preferred embodiment of the in- 
vention. For example, the coefTicient values a,, a2 may be applied in canonic sum digit (CSD) form; this approach can 
save machine cycles in the operation by eliminating addition operations for zero-value coefficient digits, as described 
above. This approach may be particularly beneficial in the case where the digital filter utilizes fixed values of the co- 
efficients, as these fixed values may be incorporated into a microcoded routine for effecting the filter. Other altemative 
approaches may also be used. 

[0087] Referring back to Figure 10. the output of register 2028, on the other hiand, is applied to shifter 208, which 
shifts the 'B' operand by a selectable number of bits, under the control of DSP controller 82. The shifted output from 
shifter 208 is applied to multiplexer 216 (along with a zero value), the output of which is applied to exclusive-OR block 
21 8 and then to a second input of adder 21 5. The least significant bits shifted out from shifter 208 are applied to carry 
control 217, along with the most significant bit of the B operand from register 202B. Carry contror217 applies a signal 
to the carry>in input of adder 215 based upon these signals, as will be described In further detafl hereinbelow. 
[0088] Adder 215 applies its output both back to Inputs of multiplexer^ '200A. 200C. 200B, and.also to data register 
85. As discussed above, data register 85 buffers the output sample value| for communicatbn to external from DSP 75. 
[0089] The operation of datapath 80 in executing an instruction according to this second preferred embodiment of 
the invention, by way of which the quantized sum of products OMTfaiYn-r + aaVo-d 's generated, where multiplications 
are carried out in a Booth-encoded manner, and where the -result is quantized according to a magnitude truncation 
approach, such as is useful in executing the recursive loop of a second-order IIR digital filter, will now be described in 
detail. 

[0090] Firstly.- coefficients a^ , ag are retrieved from BAM 76, and are stored by datapath 80 in registers 205. 207, ^or 
access by DSP controller 82. These coefficient values remain constant, at least for the execution of this particular 
recursive kxjp operation. In this example, the coefficients a^. 82 will have the foltowing values: 
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a, = 182153 = 01.110100102 



ag ~ -0.86813 = 1 1.OO'lOOOlOg 

The ten-bil two's complemenl represenlalioris of coefficients a^, utilize their MSB as a sign-bit, one integer bit, and 
eight fraction-bHs. By way of reference, the Booth encoding table for three-bit Booth encoding is as follows: 
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Coefficient bits 


Booth term 


000 


0 


001 


+1 


010 


+1 


011 


+2 


100 


-2 


101 


-1 


110 


-1 


111 


0 



[0091] An input sample value x„ may next be received from external register 77, and stored in memory via multiplexer 
25 204. At this point, the output sample values y^.^ and y^.g are retrieved from RAM 76, and stored in registers 202A, 
202C, respectively. 

[0092] The generation of the first partial sum So is now performed, by datapath 80 controlling multiplexer 206 to 
select register 202A (output sample value y^^) for application to Booth encoded multiplier 210. DSP controller 82 
applies the appropriate control lines corresporiding to the towest order Booth tenm Bootho: in this case, the two LSBs 
30 c,. Co of coefficient a^ plus the implied zero (100) results in Booth term Bootho "2, from the above table. Inversion 
is effected, in this case, by exclusive-OR function 212, considering that all values are in two's complemenl form in 
datapath 80. As such, the output of Booth encoded multiplier 21 0 and exclusive-OR function 21 2 (and thus the output 
of clip circuit 21 4 applied to adder 21 5), is the partial sum S=0: . 



So = -2y^i 

Multiplexer 216 is controlled to select Its 0 input, such that the output of adder 215 is simply partial sum S^,, which is 
stored in one of the registers (e.g., register 202B).- 

40 [0093] Pa rtial sum 1s next generated by multiplexer 206 selecting the output of registers 202C (which stores output 
sample value y^a) ajaplication to Booth encoded multiplier 210. Booth encoded rriultiplier 210 Is controlled by DSP 
controfler 82 to apply the lowest order (for coefficient as) Booth term Booths thereto, resulting in the generation of the 
value -2yn.2 in this example (Boothi = -2. due to the LSBs c^, Cq of coefficient ag being 1 0 as in the case of coefficient 
ai ). Inversion is handled by exclusive-OR function 212. Meanwhile, the contents of register 202B (partial sum Sq) are 

45 forwarded through shifter 208 without shift, and selected by multiplexer 216 for application to adder 215. Adder 215 
then generates partial sum S^ as follows: 

S,=.2y„.2 + So / 

so : . 

Partial sum is then stored in registers 202B. ' 

[0094] The process of generating the sequence of partial sums then continues, with output sample value y^.^ again 
retrieved from RAM 76 (or from some other local register), and stored in register 202A. This value is applied to Booth 
encoded multiplier 210 (via multiplexer 206), and multiplied by the next Booth Xerm Boothg. In this case, the Booth 
55 encoding analyzes bits C3, Cg, Ci of coefficient a^ , thus generating Booth term Booth2 as +1 . The output of clip circuit 
21 4 (assuming no overflow) applied, to one input of adder 21 5 is thus +y^i . Meanwhile,- partial sum S^ is applied from 
register 2028 to shifter 208, and shifted right two bit positions to correspond to the. higher order multiplication being 
carried out by Booth encoded multiplier 210. The least two significant bits of partial sum S, are applied to carry control 
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217 (and are effectively ORed therein), and the shifted output of shifter 208 (which corresponds to partial sum 
divided by four) Is applied to the second input of adder 215; no carry-in is generated at this point. Adder 215 then 
generates the next partial sum S2 as follows: 



This partial sum S2 is then fed back and stored In register 202B, as before. 

[0095] Partial sum S3 is then generated in asimilar fashiori except that coefficient y^2 'S applied to Booth encoded 
multiplier 210, and that partial sum S2 stored In register 2028 is not shifted by shifter 208. considering that the bit 
positions in coefficient ag that generate Booth temi Boothg are the same as those in coefficient that generated Booth 
term Boothg (i.e., the multiplications are of the same power). Partial sum S3 is then stored in register 2028, as before. 
[0096] The process.of generating partial sums S4 through Sg, In this example, is then continued in similar fashion, 
but alternating between coefficients y^^, y^2 ^r each pass, and shifting by a factor of four in altemating passes. \n 
this example, with the above values of coefficients a,, a^. the partial sums S3 through Sg correspond to the following: 



i 
i 

25 S5 = -2y„.2+S4 



S6 = -yn.i - [VJ 



S7 = y^2 + S6 



S9 = -yn-2+SB 

[0097] Upon generatbn of the final partial sum 89. datapath 80 generates the final sum S^q (which, together with 
any non-recursive term, generates current output sample value y„), by applying final partial sum Sg to adder 215, 
preferably via register 202B. so that the MSB of final partial sum S9 is applied to carry control 217 (the other Input of 
adder 215. is preferably set to 0). A carry-in-bit to adder 215 is generated by carry control 217 determining whether 
final partial surri Sg is negative (its MSB "1 ") and. if so. whether any of .lhe shifted out bits from shrfter 208 during the 
process (corresponding to fractional parts F) were non-zero; if both cbhditions are satisfied, a "I" is applied to the 
carry-in input of adder 215, so as to increment final partial sum Sg by one in generating final sum S^o- In any event, 
final sum S^q is then forwarded to RAM 76, via a selected one of registers 202. 

[0098] As is evident from this description, programmable logic, particularly the datapath in a DSP device, can readily 
and efficiently implement the generation of the recursive portion of a secondKJrder IIR digital filter according to the 
present Invention. Preferably, the operation described above relative to the operation of datapath 80 in this regard is 
implemented by way of a special Instruction In the instruction set, microcoded into ROM 78. If this approach is taken, 
then the quantized sum of products instruction may also readily be used in generating the non-recursive term in the 
IIR digital filter, and in FIR digital filters if desired. In any event, especially in the case when applied to the recursive 
loop in an IIR digital filter, the magnitude truncation quantization precludes the manlfestatbn ot limit cycles, as noted 
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above. 

[0099] The above realization of datapath 80 effectively utilizes a single pipeline ALU architecture. According to an 
alternative realization, datapath 80' of Figure 11 utilizes a dual pipeline ALU architecture, as will now be described. 
[0100] Much of the construction of datapath 80' is sinnllar to datapath 80 described hereinabove. Specifically, Input 
5 sample values, are received from EREG 77 and applied, via multiplexer 304. to RAM 76. Data read from RAM 76 are 
applied to inputs of multiplexers 300A. 300C, 300B, as are data from adder 315. R register 305 and S register 307 
store the coefficient values a^, as before. Multiplexers 300A, 300C. 300B have their outputs applied to registers 
302A, 302C, 302B. respectively, under the control of DSP controller 82. The outputs of registers 302A, 302C are applied 
to memory multilpexer 304, and to inputs of multiplexer 306. which has an output fonftrarded to a series of arithmetic 
10 and logic units in one of the dual pipelines in datapath 80*. In this example, this pipeline includes a one-bit left shifter 
310. which selectively multiplies its input operand by a factor of 2; XOR/zero function 312 Is provided to invert or zero 
the shifted output of shifter 310. As such, functions 310. 312 operate to effectively perform a three-bit Booth encoded 
multiply, storing the result In P register 313. Clip circuit 314, in this embodiment, is in a bypass path around functions 
310, 312, and Is applied to one Input of data multiplexer 320. 

[01 01 ] The output of register 302B, on the other hand, is applied to right shifter 208. which shifts the 'B' operand by 
a selectable number of bits, under the control of DSP controller 82. The least significant bits shifted out from shifter 
308 are applied to carry control 317. along with the most significant bit of the B operand from register 302B. Carry 
control 217 applies a signal to the carry-in input of adder 315 based upon these signals, as described above. The 
shifted output from shifter 308 is applied to exclusiveOR/zero function 309 and then to Q register 317 via multiplexer 
20 316. A second input of multiplexer 316 receives the feedback result from data multiplexer 320. 

[0102] P register 31 5 and Q register 317 are each applied to inputs of adder 315. Adder 31 5 applies its output to a 
2-blt left or right shifter 31 9, and then to data multiplexer 320, the output 61 which is both fedback to inputs of multiplexers 
300A, 300C, 300B, and also to data register 85. 2-bit left or right shifter 31 9 has an output applied to carry control 31 7, 
by way of which two least significant bits are fonwarded to carry control 317 in the event that a right shift is effected.* 
25 As discussed above, data register 85 buffers the output sample values for communication to external from DSP 75. 
[0103] The general operation of datapath 80' in producing the partial sums Sq through Sg and final sum S^q is equiv- 
alent to that described hereinabove relative to datapath 80 of Figure 10. However, the provision of shifter 319 at the 
output of adder 315, in combination with P register 313 and Q register 317, enable the use of two paths in datapath 
80' to be used in parallel in datapath 80'. Specifically, the feedback directly from the output of data multiplexer 320 to 
30 multiplexer 316 provides for immediate feedback of a partial sum for addition with the next product term being generated 
by shifter 310 and XOR/zero function 312; selected operation of shifter 319 shifts, or does not shift, the previously 
generated partial sum, depending upon which partial sum is being produced. It is therefore contemplated that datapath 
80' is particularly efficient in executing the quantized sum of products used in the recursive (and. If desired, non- 
recursive) path of digital filters. - 
35 [0104] Furthermore, each of datapaths 80, 80' utilize adders which are only of the same precision as the signal 
precision. Additional precision that is required due to coefficient multiplication is not necessary, because of the present 
invention. Each of the above embodiments provide the important benefit of eliminating limit cycles from IIR digital filters, 
while still enabling reduced precision adders to be used in the realization of these filters. It is therefore contemplated 
that the present invention will be of benefit in many types of applications In which IIR digital filters are utilized. 
^0 [0105] While the present invention has been described according to its preferred embodiments, it is of course con- 
• templaled that modifications of, and alternatives to, these embodiments, such modifications and alternatives obtaining 
the advantages and benefits of this Invention, will be apparent to those of ordinary skill in the art having reference to 
this specification and its drawings. It is contemplated that such nxxiificatlons arid alternatives are within the scope of 
this Invention as subsequently claimed herein. 
^5 [0106] An electronic device, comprising: 

a memory for storing instruction codes, input sample values, and output sample values; 

a controller, for receiving instruction codes from the memory and for generating control signals based thereupon; 

and • \ 

a datapath, coupled to the controller, for executing a sequence of -iristructions responsive to the control signals 
from the controller, the sequence of instructions comprising: 

retrieving first and second coefficient values and first and second output sample values from the memory: 
applying a least significant digit of the first coefficient value to the first output sample value to produce a first 
partial sum in a sequence of partial sums; 

adding the first partial sum to a value determined by applying a least significant digit of the second coefficient 
value to the second output sample value, to produce a next partial sum in the sequence of partial sums; 
shifting the next partial sum according to a difference In order between the least significant digit of the second 
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coefficient value and a next digit of the First coefficient value to produce a shifted next partial sum, and a 
fractional portion comprised of one or more of least significant bits of the next partial sum; 
after the shifting step, adding the shifted next partial sum to a value determined by applying the next digit of 
the first coefficient value to the first output sample value to produce another next partial sum in the sequence 
of partial sums; 

successively performing the adding, shifting, and adding steps according to the first and second coefficient 
values, to produce a final partial sum in the sequence of partial sums; and 
generating a feedback value based upon the final partial sum. 

[0107] The electronic device above, wherein the operation of generating a feedback value comprises: 

generating a carry signal responsive to the sign of the final partial sum and a logical OR operation of the fractional 
portions from the shifting step; and 

adding the final partial sum with the carry signal to produce the feedback value. 
[0108] The electronic device above, wherein the applying operations each comprise: 



performing a Booth encoding operation upon a group of bits of a corresponding coefficient value; 
controlling a multiply circuit to multiply a corresponding output sample value according to the results of the per- 
20 forming step. 

[0109] The electronic device above, wherein the datapath comprises: 



a Booth encoded multiplier for multiplying an operand responsive to control signals from the controller; 
an inverting circuit, for inverting the multiplied operand responsive to control signals from the controller; 
a shifter, for shifting an operand by a selectable number of bit positions, responsive to control signals from the 
controller; 

carry control circuitry, having an input coupled to the shifter, and having another input for receiving a sign-bit of an 
operand; 

30 an adder, having a first input coupled to the inverting circuit, having a second Input coupled to the shifter, and 
having a carry input coupled to the carry control circuitry; and 

a feedback path from the output of the adder to inputs of the Booth encoded multiplier and shifter 



[0110] The electronic device above, wherein the datapath comprises: 
a fit^st pipeline, comprising: 



a left shifter, for multiplying an operand responsive to control signals from the controller; 
an Inverting circuit, for Inverting the multiplied operand responsive to control signals from the controllen 
^0 a first result register, coupled to the inverting circuit; 

a second pipeline, comprising: 

a right shifter, for shifting an operand by a selectable number of bit positions, responsive to control signals 
45 from the controller; 

a second result register coupled to the right shifter; 

"V " ■ 

carry control circuitry, having an input coupled to the shifter, and havmg another input for receiving a sign-bit of an 
operand; 

an adder, having a first input coupled to the first result register, having a second input coupled to the second result 
register, and having a carry Input coupled to the cany control circuitry; 
a shifter, coupled to the output of the adder; and 
a feedback path from the output of the shifter to the second pipeline. 



Claims 

1 . A method of determining a feedback value in a digital filter, the feedback value corresponding to a sum of first and 
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second products, the first product corresponding to a first coefficient value times a -first output sample value, and 
the second product corresponding to a second coefficient value times a second output sample value, comprising 
the steps of: . 

5 . applying a least significant digit of the first coefficient value to the first output sample value to produce a first 

partial sum in a sequence of partial sums; 

adding the first partial sum to a value determined by applying a least significant digit of the second coetficlent 
value to the second output sample value, to produce a next partial sum in the sequence of partial sums; 
shifting the next partial sum according to a difference in order between the least significant digit of the second 
coefficient value and a next digit of the first coefficient value to produce a shifted next partial sum, and a 
fractional portion comprised of one or more of least significant bits of the next partial sum; 
after the shifting step, adding the shifted next partial sum to a value determined by applying the next digit of 
the first coefficient value to the first output sample value to produce another next partial sum in the sequence 
of partial sums; 

successively performing the adding, shifting, and adding steps according to the first and second coefficient 
values, to produce a final partial sum in the sequence of partial sums; and 
generating the feedback value based upon the final partial sum. 

2, The method of claim 1 . wherein the step of generating the feedback value comprises: 

20 

generating a carry signal responsive to the sign of the final partial sum -and a logical OR operation of the 
fractional portions from the shifting step; and 

adding the final partial sum with the carry signal to produce the feedback value. 
25 3. The method of claim 1 , further comprising: 

after the step of applying a least significant digit of the first coefficient value to the first output sample value, 
determining whether the next significant digit of the first coefficient value Is of lower order than the least sig- 
nificant digit of the second coefficient value; 

30 responsive to the next significant digit of the first coefficient value being of lower order than the least significant 

digit of the second coefficient value, then adding the first partial sum to a value determined by applying the 
next significant digit of the first coefficient value to the first output sample value, to produce a next partial sum; 
shifting the next partial sum according to a difference in order between the least significant digit of the first 
coefficient value and a next digit of the first. coefficient value to produce a shifted next partial sum, and a 

35 fractional portion comprised of one or more of least significant bits ot the next partial sum. 

4. The method of claim 1 , wherein the first and second coefficient values are in canonic sum digit form. 

5. The method of claim 1 , wherein the applying steps each comprise: 

40 

performing a Booth encoding operation upon a group of bits of a corresponding coefficient value; 
controlling a multiply circuit to multiply a corresponding output sample value according to the results of the 
performing step. 

45 6. The method of claim 1 . further comprising: 

performing a feed-fonward filter operation upon a sequence of input sample values to generate a feed-forward 
result; and / 

adding the final partial sum to the carry signal and to the feed-fory/$rd result, to produce an output sample value.. 
The method of claim 6, further comprising: 

applying a high-pass digital filter to the sequence of Input sample values, prior to the step of pertomiing a 
feed-fonward filter operation, 

55 

8. The method of claim 1 , further comprising: 

storing the first and second coefficient values In a memory, prior to the step of applying a least significant digit 
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of the first coefficient value to the first output sample value. 

9. A digital filter circuit, comprising: 

5 a plurality of adders, each having an input for receiving one of a first output sample value and a second output 

sample value, and having an output for presenting a partial sum; and 

a plurality of shifters, each having an input coupled to the output of one of said adders to receive a correspond- 
ing partial sum. having a shift output for presenting a shifted partial sum to an input of one of said plurality of 
adders, and having a fraction output for presenting a fractional portion of the shifted partial sum, each of the 
• plurality of shifters for shifting the partial sum at its input by a number of bit positions corresponding to a 
difference In order between successive significant digits of first and second coefficient values; 
wherein the plurality of adders and the plurality of shifters are arranged in a sequence corresponding to sig- 
nificant digits of the first and second coefficient values from least significant to most significant, with at least 
one of the plurality of adders receiving the second output sample value disposed between first and second 
ones of the plurality of adders receiving the first output sample value. 

10. The digital filter of claim 9, further comprising: 

conjunctive logic having inputs coupled to receive fractional porlfons of shifted partial sums from each of the 
plurality of shifters, having an input to receive a sign-bit from the output of a last one of the plurality of adders, 
and having an output for generating a carry signal; . * 

a final adder, having ah input coupled to the conjunctive logic to receive the carry signal, and having an input 
coupled to receive a final partial sum from the last one of the plurality of adders, for generating a final sum. 

25 11. The digital filter of claim 10, further comprising: 

a feed-fonvard portion, having an input coupled to receive a sequence of input sample values, ^nd having an 
output coupled to the final adder. . 

30 12. The digital filter of claim 11 , further comprising: 

a high-pass filter, coupled to the input of the feedforward portion, for filtering the sequence of input sample 
values. 
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(54) Digital filter with efficient quantization circuitry 



(57) An infinite impulse response (IIR) digital filter 
and method of perfomriing the same is disclosed. The 
digital filter may be realized by way of a programmable 
logic device, such as a digital signal processor (75), or 
altemativety by way of dedicated logic including adders 
(44, 48, 50, 54, 58, 62, 66. 70. 72) and shifters (46, 52, 
56, .60, 64). In either case, addition operations (34) are 



interleaved among first and second output sample val- 
ues (y^.^, yn.2). so that the resulting addition (30; 72; 
215; 320) may be carried out with adder circuitry of the 
same precision as the signal Input (xj and signal output 
(y^). Cany control circuitry (76, 78, 80, .82. 84, 88; 217; 
317) is provided to efficiently incorporate magnitude 
truncation quantization. 
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